package f2100t2200;

import java.util.Arrays;

/*
2125. 银行中的激光束数量
中等
提示
银行内部的防盗安全装置已经激活。给你一个下标从 0 开始的二进制字符串数组 bank ，表示银行的平面图，这是一个大小为 m x n 的二维矩阵。 bank[i] 表示第 i 行的设备分布，由若干 '0' 和若干 '1' 组成。'0' 表示单元格是空的，而 '1' 表示单元格有一个安全设备。

对任意两个安全设备而言，如果同时 满足下面两个条件，则二者之间存在 一个 激光束：

两个设备位于两个 不同行 ：r1 和 r2 ，其中 r1 < r2 。
满足 r1 < i < r2 的 所有 行 i ，都 没有安全设备 。
激光束是独立的，也就是说，一个激光束既不会干扰另一个激光束，也不会与另一个激光束合并成一束。

返回银行中激光束的总数量。
 */
public class BankLaserCount_2125 {
    public static int resolve() {
        String[] bank = {"000","111","000"};
        return new Solution().numberOfBeams(bank);
    }
}
class Solution {
    public int numberOfBeams(String[] bank) {
        if (bank.length <= 1) {
            return 0;
        }
        long cnt = 0;
        long preCnt = 0, curCnt = 0;
        for (String line : bank) {
            curCnt = line.chars().filter(c -> c == '1').count();
            if (curCnt != 0) {
                cnt += preCnt * curCnt;
                preCnt = curCnt;
            }
        }
        return (int) cnt;
    }
}
